# 2 Inverter Control with Space Vector Modulation

The figure 2.1a shows the principle circuit of an inverter fed 3-phase AC motor with three phase windings u, v and w. The three phase voltages are applied by three pairs of semiconductor switches  $v_{u+}/v_{u-}$ ,  $v_{v+}/v_{v-}$  and  $v_{w+}/v_{w-}$  with amplitude, frequency and phase angle defined by microcontroller calculated pulse patterns. The inverter is fed by the DC link voltage  $U_{DC}$ . In our example, a transistor inverter is used, which is today realized preferably with IGBTs.



Fig. 2.1a Principle circuit of a VSI inverter-fed 3-phase AC motor

Figure 2.1b shows the spacial assignment of the stator-fixed  $\alpha\beta$  coordinate system, which is discussed in the chapter 1, to the three windings u, v and w. The logical position of the three windings is defined as:

- 0, if the winding is connected to the negative potential, or as
- 1, if the winding is connected to the positive potential

of the DC link voltage. Because of the three windings eight possible logical states and accordingly eight standard voltage vectors  $\mathbf{u}_0$ ,  $\mathbf{u}_1$  ...  $\mathbf{u}_7$  are obtained, of which the two vectors  $\mathbf{u}_0$  - all windings are on the negative

potential - and  $\mathbf{u}_7$  - all windings are on the positive potential - are the so called zero vectors.



**Fig. 2.1b** The standard voltage vectors  $\mathbf{u_0}$ ,  $\mathbf{u_1}$  ...  $\mathbf{u_7}$  formed by the three transistor pairs  $(Q_1 \dots Q_4$ : quadrants,  $S_1 \dots S_6$ : sectors)

The spacial positions of the standard voltage vectors in stator-fixed  $\alpha\beta$  coordinates in relation to the three windings u, v and w are illustrated in figure 2.1b as well. The vectors divide the vector space into six sectors  $S_1$  ...  $S_6$  and respectively into four quadrants  $Q_1$  ...  $Q_4$ . The table 2.1 shows the logical switching states of the three transistor pairs.

Table 2.1 The standard voltage vectors and the logic states

|   | $\mathbf{u}_0$ | $\mathbf{u}_1$ | $\mathbf{u}_2$ | $\mathbf{u}_3$ | $\mathbf{u}_4$ | $\mathbf{u}_5$ | $\mathbf{u}_6$ | $\mathbf{u}_7$ |
|---|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| u | 0              | 1              | 1              | 0              | 0              | 0              | 1              | 1              |
| V | 0              | 0              | 1              | 1              | 1              | 0              | 0              | 1              |
| W | 0              | 0              | 0              | 0              | 1              | 1              | 1              | 1              |

# 2.1 Principle of vector modulation

The following example will show how an arbitrary stator voltage vector can be produced from the eight standard vectors.



Fig. 2.2 Realization of an arbitrary voltage vector from two boundary vectors

Let us assume that the vector to be realized,  $\mathbf{u}_s$  is located in the sector  $\mathbf{S}_1$ , the area between the standard vectors  $\mathbf{u}_1$  and  $\mathbf{u}_2$  (fig. 2.2).  $\mathbf{u}_s$  can be obtained from the vectorial addition of the two boundary vectors  $\mathbf{u}_r$  and  $\mathbf{u}_l$  in the directions of  $\mathbf{u}_1$  and  $\mathbf{u}_2$ , respectively. In figure 2.2 mean:

Subscript r, l: boundary vector on the right, left

Supposed the complete pulse period  $T_p^*$  is available for the realization of a vector with the maximum modulus (amplitude), which corresponds to the value  $2U_{DC}/3$  of a standard vector, the following relation is valid:

$$\left|\mathbf{u}_{s}\right|_{\max} = \left|\mathbf{u}_{1}\right| = \dots = \left|\mathbf{u}_{6}\right| = \frac{2}{3}U_{DC}$$
 (2.1)

From this, following consequences result:

- 1.  $\mathbf{u}_s$  is obtained from the addition of  $\mathbf{u}_r + \mathbf{u}_l$
- 2.  $\mathbf{u}_r$  and  $\mathbf{u}_l$  are realized by the logical states of the vectors  $\mathbf{u}_1$  and  $\mathbf{u}_2$  within the time span:

$$T_r = T_p^* \frac{|\mathbf{u}_r|}{|\mathbf{u}_s|_{\text{max}}}; T_l = T_p^* \frac{|\mathbf{u}_l|}{|\mathbf{u}_s|_{\text{max}}}$$

$$(2.2)$$

 $\mathbf{u}_1$  and  $\mathbf{u}_2$  are given by the pulse pattern in table 2.1. Only the switching times  $T_r$ ,  $T_l$  must be calculated. From equation (2.2) the following conclusion can be drawn:

To be able to determine  $T_r$  and  $T_l$ , the amplitudes of  $\mathbf{u}_r$  and  $\mathbf{u}_l$  must be known.

It is prerequisite that the stator voltage vector  $\mathbf{u}_s$  must be provided by the current controller with respect to modulus and phase. The calculation of the switching times  $T_r$ ,  $T_l$  will be discussed in detail in section 2.2. For now, two questions remain open:

1. What happens in the rest of the pulse period  $T_p^* - (T_r + T_l)$ ?

20

2. In which sequence the vectors  $\mathbf{u}_1$  and  $\mathbf{u}_2$ , and respectively  $\mathbf{u}_r$  and  $\mathbf{u}_l$  are realized?

In the rest of the pulse period  $T_p^* - (T_r + T_l)$  one of the two zero vectors  $\mathbf{u}_0$  or  $\mathbf{u}_7$  will be issued to finally fulfil the following equation.

$$\mathbf{u}_{s} = \mathbf{u}_{r} + \mathbf{u}_{l} + \mathbf{u}_{0} \text{ (or } \mathbf{u}_{7})$$

$$= \frac{T_{r}}{T_{p}^{*}} \mathbf{u}_{1} + \frac{T_{l}}{T_{p}^{*}} \mathbf{u}_{2} + \frac{T_{p}^{*} - (T_{r} + T_{l})}{T_{p}^{*}} \mathbf{u}_{0} \text{ (or } \mathbf{u}_{7})$$
(2.3)

The resulting question is, in which sequence the now three vectors - two boundary vectors and one zero vector - must be issued. Table 2.2 shows the necessary switching states in the sector  $S_1$ .

**Table 2.2** The switching states in the sector  $S_1$ 

|   | $\mathbf{u}_0$ | $\mathbf{u}_1$ | $\mathbf{u}_2$ | $\mathbf{u}_7$ |
|---|----------------|----------------|----------------|----------------|
| u | 0              | 1              | 1              | 1              |
| V | 0              | 0              | 1              | 1              |
| W | 0              | 0              | 0              | 1              |

It can be recognized that with respect to transistor switching losses the most favourable sequence is to switch every transistor pair only once within a pulse period.

If the last switching state was  $\mathbf{u}_0$ , this would be the sequence

$$\mathbf{u}_0 \Rightarrow \mathbf{u}_1 \Rightarrow \mathbf{u}_2 \Rightarrow \mathbf{u}_7$$

but if the last switching state was  $\mathbf{u}_7$ , this would be

$$\mathbf{u}_7 \Rightarrow \mathbf{u}_2 \Rightarrow \mathbf{u}_1 \Rightarrow \mathbf{u}_0$$



**Fig. 2.3** Pulse pattern of voltage vectors in sector  $S_1$ 

With this strategy the switching losses of the inverter become minimal. Different strategies will arise if other criteria come into play (refer to sections 2.5.1, 2.5.3). If the switching states of two pulse periods succeeding one another are plotted exemplarily a well-known picture from the pulse width modulation technique arises (fig. 2.3).

Figure 2.3 clarifies that the time period  $T_p^*$  for the realization of a voltage vector is only one half of the real pulse period  $T_p$ . Actually, in the real pulse period  $T_p$  two vectors are realized. These two vectors may be the same or different, depending only on the concrete implementation of the modulation.

Until now the process of the voltage vector realization was explained for the sector  $S_1$  independent of the vector position within the sector. With the other sectors  $S_2$  -  $S_6$  the procedure will be much alike: splitting the voltage vector into its boundary components which are orientated in the directions of the two neighbouring standard vectors, every vector of any arbitrary position can be developed within the whole vector space. This statement is valid considering the restrictions which will be discussed in section 2.3. The following pictures give a summary of switching pattern samples in the remaining sectors  $S_2$  ...  $S_6$  of the vector space.





Fig. 2.4 Pulse pattern of the voltage vectors in the sectors  $S_2 \dots S_6$ 

From the fact, that:

- 1. the current controller delivers the reference value of a new voltage vector  $\mathbf{u}_s$  to the modulation after every sampling period T, and
- 2. every (modulation and) pulse period  $T_p$  contains the realization of two voltage vectors,

the relation between the pulse frequency  $f_p = 1/T_p$  and the sampling frequency 1/T is obtained. The theoretical statement from figure 2.3 is that two sampling periods T correspond to one pulse period  $T_p$ . However this relationship is rarely used in practice. In principle it holds

that the new voltage vector  $\mathbf{u}_s$  provided by the current controller is realized within at least one or several pulse periods  $T_p$ .

Thereby it is possible to find a suitable ratio of pulse frequency to sampling frequency, which makes a sufficiently high pulse frequency possible at simultaneously sufficiently big sampling period (necessary because of a restricted computing power of the microcontroller). In most systems  $f_p$  is normally chosen in the range 2,5...20kHz. The figure 2.5 illustrates the influence of different pulse frequencies on the shape of voltages and currents.



**Fig. 2.5** Pulse frequency  $f_p$  and the influence on the stator voltage as well as the stator current. 1: Pulsed phase-to-phase voltage; 2: Fundamental wave of the voltage; 3: Current

## 2.2 Calculation and output of the switching times

After the principle of the space vector modulation has been introduced, the realization of that principle shall be discussed now. Eventually the inverter must be informed on "how" and respectively "how long" it shall switch its transistor pairs, after the voltage vector to be realized is given with respect to modulus and phase angle.

Thanks to the information about phase angle and position (quadrant, sector) of the voltage vector the question "how" can be answered immediately. From the former section the switching samples for all sectors as well as their optimal output sequences with respect to the switching losses are already arranged.

The question ,,how long" is subject of this section. From equations (2.2), (2.3) it becomes obvious, that the calculation of the switching times  $T_r$ ,  $T_l$  depends only on the information about the moduli of the two boundary vectors  $\mathbf{u}_r$ ,  $\mathbf{u}_l$ . The vector  $\mathbf{u}_s$  (fig. 2.6) is predefined by:

1. Either the DC components  $u_{sd}$ ,  $u_{sq}$  in dq coordinates. From these, the total phase angle is obtained from the addition of the current angular position  $\mathcal{G}_s$  of the coordinate system (refer to fig. 1.2) and the phase angle of  $\mathbf{u}_s$  within the coordinate system.

$$\vartheta_u = \vartheta_s + \arctan\left(\frac{u_{sq}}{u_{sd}}\right) \tag{2.4}$$

2. Or the sinusoidal components  $u_{s\alpha}$ ,  $u_{s\beta}$  in  $\alpha\beta$  coordinates. This representation does not contain explicitly the information about the phase angle, but includes it implicitly in the components.



Fig. 2.6 Possibilities for the specification of the voltage vector u<sub>s</sub>

Therefore two strategies for calculation of the boundary components exist.

1. Strategy 1: At first, the phase angle  $\mathcal{G}_u$  is found by use of the equation (2.4), and after that the angle  $\gamma$  according to figure 2.6 is calculated, where  $\gamma$  represents the angle  $\mathcal{G}_u$  reduced to sector 1. Then the calculation of the boundary components can be performed by use of the following formulae, which is valid for the whole vector space:

$$\left|\mathbf{u}_{r}\right| = \frac{2}{\sqrt{3}}\left|\mathbf{u}_{s}\right| \sin\left(60^{0} - \gamma\right); \left|\mathbf{u}_{l}\right| = \frac{2}{\sqrt{3}}\left|\mathbf{u}_{s}\right| \sin\left(\gamma\right)$$
(2.5)

With:

$$\left|\mathbf{u}_{s}\right| = \sqrt{u_{sd}^{2} + u_{sq}^{2}} \tag{2.6}$$

2. Strategy 2: After the coordinate transformation, the stator-fixed components  $u_{s\omega}$   $u_{s\beta}$  are obtained from  $u_{sd}$ ,  $u_{sq}$ . For the single sectors,  $\mathbf{u}_r$  and  $\mathbf{u}_l$  can be calculated using the formulae in table 2.3.

**Table 2.3** Moduli of the boundary components  $\mathbf{u}_r$ ,  $\mathbf{u}_l$  dependent on the positions of the voltage vectors

|       |       | $ \mathbf{u}_r $                                                        | $ \mathbf{u}_l $                                                        |  |  |
|-------|-------|-------------------------------------------------------------------------|-------------------------------------------------------------------------|--|--|
| $S_1$ | $Q_1$ | $ u_{s\alpha}  - \frac{1}{\sqrt{3}}  u_{s\beta} $                       | $\frac{2}{\sqrt{3}} u_{s\beta} $                                        |  |  |
| C     | $Q_1$ | $\left u_{s\alpha}\right  + \frac{1}{\sqrt{3}}\left u_{s\beta}\right $  | $- u_{s\alpha} +\frac{1}{\sqrt{3}} u_{s\beta} $                         |  |  |
| $S_2$ | $Q_2$ | $- u_{s\alpha} +\frac{1}{\sqrt{3}} u_{s\beta} $                         | $\left u_{s\alpha}\right  + \frac{1}{\sqrt{3}} \left u_{s\beta}\right $ |  |  |
| $S_3$ | $Q_2$ | $\frac{2}{\sqrt{3}} u_{s\beta} $                                        | $\left u_{s\alpha}\right  - \frac{1}{\sqrt{3}} \left u_{s\beta}\right $ |  |  |
| $S_4$ | $Q_3$ | $ u_{s\alpha}  - \frac{1}{\sqrt{3}}  u_{s\beta} $                       | $\frac{2}{\sqrt{3}} u_{s\beta} $                                        |  |  |
| C     | $Q_3$ | $\left u_{s\alpha}\right  + \frac{1}{\sqrt{3}} \left u_{s\beta}\right $ | $- u_{s\alpha} +\frac{1}{\sqrt{3}} u_{s\beta} $                         |  |  |
| $S_5$ | $Q_4$ | $- u_{s\alpha} +\frac{1}{\sqrt{3}} u_{s\beta} $                         | $\left u_{s\alpha}\right  + \frac{1}{\sqrt{3}} \left u_{s\beta}\right $ |  |  |
| $S_6$ | $Q_4$ | $\frac{2}{\sqrt{3}} u_{s\beta} $                                        | $\left u_{s\alpha}\right  - \frac{1}{\sqrt{3}} \left u_{s\beta}\right $ |  |  |

The proposed strategies for the calculation of the switching times  $T_n$   $T_l$  are equivalent. The output of the switching times itself depends on the hardware configuration of the used microcontroller. The respective procedures will be explained in detail in the section 2.4.

The application of the 2<sup>nd</sup> strategy seems to be more complicated in the first place because of the many formulae in table 2.3. But at closer look it will become obvious that essentially only three terms exist.

$$\mathbf{a} = \left| u_{s\alpha} \right| + \frac{1}{\sqrt{3}} \left| u_{s\beta} \right|; \mathbf{b} = \left| u_{s\alpha} \right| - \frac{1}{\sqrt{3}} \left| u_{s\beta} \right|; \mathbf{c} = \frac{2}{\sqrt{3}} \left| u_{s\beta} \right|$$
 (2.7)

With the help of the following considerations the phase angle of  $\mathbf{u}_s$  can be easily calculated.

1. By the signs of  $u_{s\alpha}$ ,  $u_{s\beta}$  one finds out in which of the four quadrants the voltage vector is located.

26

2. Because the moduli of  $\mathbf{u}_r$  and  $\mathbf{u}_l$  are always positive, and because the term  $\mathbf{b}$  changes its sign at every sector transition,  $\mathbf{b}$  can be tested on its sign to determine to which sector of the thus found quadrant the voltage vector belongs.

## 2.3 Restrictions of the procedure

For practical application to inverter control, the vector modulation algorithm (VM) has certain restrictions and special properties which implicitly must be taken into account for implementation of the algorithm as well as for hardware design.

#### 2.3.1 Actually utilizable vector space

The geometry of figure 2.2 may lead to the misleading assumption that arbitrary vectors can be realized in the entire vector space which is limited by the outer circle in fig. 2.7b, i.e. every vector  $\mathbf{u}_s$  with  $|\mathbf{u}_s| \leq 2U_{DC}/3$  would be practicable. The following consideration disproves this assumption: It is known that the vectorial addition of  $\mathbf{u}_r$  and  $\mathbf{u}_l$  is not identical with the scalar addition of the switching times  $T_r$  and  $T_l$ . To simplify the explanation, the constant half pulse period which, according to fig. 2.3, is available for the realization of a vector is replaced by  $T_{p/2} = T_p/2$ . After some rearrangements of equation (2.2) by use of (2.5) the following formula is obtained.

$$T_{\Sigma} = T_r + T_l = \sqrt{3} T_{p/2} \frac{|\mathbf{u}_s|}{U_{DC}} \cos(30^0 - \gamma)$$
 (2.8)

In case of voltage vector limitation, that is  $|\mathbf{u}_s| = 2U_{DC}/3$ , it follows from (2.8):

$$T_{\Sigma \max} = T_{p/2} \frac{2}{\sqrt{3}} \cos(30^0 - \gamma)$$
 with  $0^0 \le \gamma \le 60^0$  (2.9)

The diagram in figure 2.7a shows the fictitious characteristic of  $T_{\Sigma \max}$  with excess of the half pulse period  $T_{p/2}$ . By limitation of  $T_{\Sigma}$  to  $T_{p/2}$  the actual feasible area is enclosed by the hexagon in fig. 2.7b.

In some cases in the practice - e.g. for reduction of harmonics in the output voltage - the hexagon area is not used completely. Only the area of the inner, the hexagon touching circle will be used. The usable maximum voltage is then:

$$\left|\mathbf{u}_{s}\right|_{\text{max}} = \frac{1}{\sqrt{3}} U_{DC} \tag{2.10}$$

Thus the area between the hexagon and the inner circle remains unused. Utilization of this remaining area is possible if the voltage modulus is limited by means of a *time limitation* from  $T_{\Sigma}$  to  $T_{p/2}$ . To achieve this, the zero vector time is dispensed with, and only one transistor pair is involved in the modulation in each sector (refer to fig. 2.14d, right). A *direct modulus limitation* will be discussed later in connection with the current controller design.



**Fig. 2.7** Temporal (a) and spacial (b) representation of the utilizable area for the voltage vector  $\mathbf{u}_s$ 

An important characteristic for the application of the VM is the voltage resolution  $\Delta u$ , which for the case of limitation to the inner circle or at use of equation (2.10) can be calculated as follows:

$$\Delta u = \frac{2}{\sqrt{3}} \frac{\Delta t}{T_p} U_{DC} \left[ \mathbf{V} \right] \tag{2.11}$$

At deeper analysis, restricted on the hexagon only, it turns out that the zero vector times become very small or even zero if the voltage vector approaches its maximum amplitude. This is equivalent to an (immediate) switch on or off of the concerned transistor pair after it has been switched off or on. For this reason the voltage vector moduli have to be limited to make sure the zero vector times  $T_0$  and  $T_7$  never fall below the switching times of the transistors. For IGBT's the switching times are approx. <1...4 $\mu$ s, so that this contraction of the voltage vector for usual switching frequencies of 1...5kHz can be considered insignificant. However, the situation becomes more critical for higher switching frequencies or if slow-switching semiconductors, such as thyristors, are used.

The values either of  $T_r$  or of  $T_l$  become very small in the boundary zone between the sectors or near one of the standard vectors  $\mathbf{u}_1$  ...  $\mathbf{u}_6$ . For some commonly used digital signal processing structures (refer to the application example with TMS 320C20/C25 in section 2.4) the PWM synchronization is directly coupled to the interrupt evaluation of the timer counters for  $T_r$  and  $T_l$ . For these structures the values of  $T_r$  and  $T_l$  must never fall below the interrupt reaction times causing another limitation of the utilizable area. The arising forbidden zones are shown in figure 2.8.



Fig. 2.8 Forbidden zones in the vector space

# 2.3.2 Synchronization between modulation and signal processing

According to theory (refer to fig. 2.3) the modulated voltage in the context of control or digital signal processing looks like in figure 2.9 for the samplings periods (k-1), (k) and (k+1). The voltage output sequence in period (k)

$$T_r(\mathbf{u}_r) \Rightarrow T_l(\mathbf{u}_l) \Rightarrow T_7(\mathbf{u}_7) / T_l(\mathbf{u}_l) \Rightarrow T_r(\mathbf{u}_r) \Rightarrow T_0(\mathbf{u}_0)$$

leads to the following time relation:

$$T_{synch} = T_p - \frac{T_0(\mathbf{k})}{2} + \frac{T_0(\mathbf{k} - 1)}{2}$$

For a dynamic process with  $\mathbf{u}_s(k-1) \neq \mathbf{u}_s(k)$  is also  $T_o(k-1)/2 \neq T_o(k)/2$ . That means, that  $T_{synch}$  would be not constant (fig. 2.9b), making the use of up/down counters – like usually done in PWM units – impossible. Therefore, a different sequence shall be used for voltage output:

$$\frac{T_0}{2}(\mathbf{u}_0) \Rightarrow T_r(\mathbf{u}_r) \Rightarrow T_l(\mathbf{u}_l) \Rightarrow T_7(\mathbf{u}_7) / T_l(\mathbf{u}_l) \Rightarrow T_r(\mathbf{u}_r) \Rightarrow \frac{T_0}{2}(\mathbf{u}_0)$$

Figure 2.9b shows this alternative sequence. It is obvious from the figure that this sequence is absolutely stable and therefore the use of up/down counters is supported. This means also *a strict synchronization between control and pulse periods* which must be considered already in the design phase of the signal processing hardware.



**Fig. 2.9** For ensuring synchronization between modulation and control: the theoretical sequence (a) must be modified (b)

# 2.3.3 Consequences of the protection time and its compensation

So far, the semiconductors had been regarded as ideal switches with undelayed turn-on and turn-off characteristics. However, the IGBT's physically reach their safe switched-on or switched-off state only after a certain turn-on or turn-off period  $t_{on}$ ,  $t_{off}$ . To avoid inverter short circuit, the switch-on edge of the control signal must be delayed for a time  $t_D$  which is greater than the turn-off time  $t_{off}$ . This time is called protection time or blanking time (fig. 2.10). In practice  $t_D$  is chosen so that  $t_{off}$  will be nearly 70 ... 80% of  $t_D$ .



Fig. 2.10 Origin of the protection time  $t_D$  and its influence on the output voltage

Figure 2.10b shows in turn: **1.** The reference voltage  $u_v^*$  for the phase v. **2.** The actual IGBT control signals  $v_+$  and  $v_-$ , modified by the protection time  $t_D$ . **3.** The actual voltage  $u_v$  of phase v. **4.** The voltage errors  $\Delta u_v$ . The influence of  $t_D$  on the trajectory of the stator voltage vector  $\mathbf{u}_s$  as well as on the fundamental wave of the phase voltage are illustrated in figures 2.10c,d.

The voltage error  $\Delta u_v$ , caused by  $t_D$  and shown in figure 2.10d, can be calculated as follows:

$$\Delta u_{v} = u_{v}^{*} - u_{v} = \begin{cases} -\frac{t_{D}}{T_{p}} \left( \frac{2}{3} U_{DC} \right) & \text{for } i_{sv} > 0 \\ \frac{t_{D}}{T_{p}} \left( \frac{2}{3} U_{DC} \right) & \text{for } i_{sv} < 0 \end{cases}$$
(2.12)

The voltage error depends on the sign of the phase current and may be effectively compensated with respect to the voltage mean average value. This compensation can be realized either in hardware or in software. *Software compensation* is more widely used today. Preferably, the compensation is done without using the actual current feedbacks which could be critical because of the pulsed current as well as the measuring noise at zero crossings. This is possible if the current controller works without delay. In chapter 5 it will be shown that this condition is largely fulfilled for the control algorithms to be introduced there.

In this case the reference value can be used to capture the sign instead of the actual value. The reference values  $i_{su}^*$ ,  $i_{sv}^*$  and  $i_{sw}^*$  of the phase currents can be calculated from  $i_{sd}^*$ ,  $i_{sq}^*$  by use of a coordinate transformation. With that the error components in  $\alpha\beta$ -coordinates are obtained as follows:

$$\begin{cases} \Delta u_{s\alpha} = \left[ -sign(i_{su}^*) + \frac{1}{2}sign(i_{sv}^*) + \frac{1}{2}sign(i_{sw}^*) \right] \frac{t_D}{T_p} \left( \frac{2}{3} U_{DC} \right) \\ \Delta u_{s\beta} = \left[ -sign(i_{sv}^*) + sign(i_{sw}^*) \right] \frac{t_D}{T_p} \left( \frac{2}{3} U_{DC} \right) \frac{\sqrt{3}}{2} \end{cases}$$
(2.13)

The error components according to (2.13) are added to the stator-fixed voltage components  $u_{s\omega}$   $u_{s\beta}$  before they are forwarded to the modulation.

### 2.4 Realization examples

The realization of the space vector modulation requires a suitable periphery, which has to be added to the processor hardware when normal microprocessors ( $\mu P$ ) or digital signal processors (DSP) are used. However, a number of microprocessors with this periphery on chip, so called micro controllers ( $\mu C$ ) are available on the market today, allowing implementation of advanced modulation algorithms without additional hardware.



 $\textbf{Fig. 2.11} \ \ \text{Flow chart for the computing of the switching times according to the space vector modulation}$ 

Microcontrollers, which are utilizable for 3-phase AC machine systems due to their internal PWM units as well as other on-chip periphery units, are e.g.

- 1. SAB 80C166, SAB C167 (Siemens, Infineon): The time resolution  $\Delta t$  of C166 is 400 ns, of C167 50 ns. The upper and the lower transistor of a phase leg are not controllable separately using the C167-PWM unit<sup>1</sup>, which would be necessary for an efficient, software based generation of the protection time. A 32 bit single chip microcontroller of the TC116x series can be used very advantageously today for a high-quality drive.
- 2. TMS 320C240/F240 (Texas Instruments):  $\Delta t = 50$ ns. The  $\mu$ C supports the direct generation of the protection time  $t_D$ , and the transistors of a pair are controllable independently. Also, chips of the family TMS 320 F281x are used very widely today.

In many systems a double processor configuration is used due to the strong price collapse of the processors in the last years. For such applications, the digital signal processors from Texas Instruments TMS 320C25 (16 Bit, fixed-point arithmetic) or TMS 320C32 (32 Bit, floating-point arithmetic) can be recommended particularly.

The application of the modulation algorithm, described in sections 2.1 and 2.2, shall be illustrated now in detail on 4 examples, orientated essentially on the Siemens microcontrollers SAB 80C166, SAB C167 and the Texas Instruments DSP TMS 320C20/C25. The calculation of the switching times is carried out according to the  $2^{nd}$  strategy of section 2.2, i.e. by means of the  $\alpha\beta$  voltage components.

In principle, the concrete formulae for the computing of the switching times in all sectors shall be worked out first using table 2.3. These formulae will then be used on-line. The computing and output will be independent of the hardware following the flow chart in the figure 2.11. The flow chart clarifies the steps to determine the space vector area in which the voltage vector to be realized is located. After that, the computing, dependent on the respective hardware, will follow.

#### 2.4.1 Modulation with microcontroller SAB 80C166

The microcontroller SAB 80C166 is a special high-performance microprocessor with an extensive periphery on the chip. Particularly the Capture/Compare register unit supports the space vector modulation for 3-

<sup>&</sup>lt;sup>1</sup> This is possible, however, if the modulation is not realized with PWM units but with CAPCOM registers

34

phase AC machines. The double register compare mode is used in the following example.



**Fig. 2.12a** Hardware configuration for the space vector modulation using the microcontroller SAB 80C166 in double register compare mode

In double register compare mode the 16 CapCom registers CC0-CC15 are configured in two register banks and assigned in pairs to one of the two timers T0 or T1 respectively. E.g. the three pairs CC0/CC8, CC1/CC9 and CC2/CC10 with the inputs/outputs CC0IO/P2.0, CC1IO/P2.1 and CC2IO/P2.2, which are configured as outputs here, shall be used. The simplified hardware structure to control the inverter is shown in the figure 2.12a. The assignment of the register pairs to the inverter phase legs is represented in the figure 2.12b.



Fig. 2.12b Assignment of the register pairs to the switching times of the inverter legs

The modulation works in a fixed time frame with the pulse period  $T_p$ , which represents at the same time the reload value  $T_{reload}$  for the timer T0. This stable time frame supports the synchronization between the hardware hierarchies as well as between digital control, modulation and current measurement, which shall be discussed later. Thus, the reload register T0REL must be loaded with  $T_p$  only once at processor initialization. In the current sampling period (k) the turn-on/turn-off times  $T_{u\_on}$ ,  $T_{u\_off}$ ,  $T_{v\_on}$ ,  $T_{v\_off}$ ,  $T_{w\_on}$  and  $T_{w\_off}$  of the inverter legs will be calculated and stored intermediately in a RAM table. An interrupt signal T0IR is triggered at overflow of the timer T0 which causes the transfer of the reload value from the register T0REL into timer T0. The interrupt signal T0IR at the same time activates an interrupt service routine to load the new switching times from the RAM table into the register pair for the following sampling period. In the next sampling period (k+1) and while the timer T0 is counting up, the compare matches between:

T0 and CC0, CC1 and CC2 as well as T0 and CC8, CC9 and CC10

cause the switchover of the phases u, v and w to

the positive or respectively

the negative potential

of the DC link voltage  $U_{DC}$ . The voltage components  $u_{s\alpha}$  and  $u_{s\beta}$  are normalized to the maximum value  $2U_{DC}/3$  in the following calculations, so that an extra index is neglected following the definition of the times introduced in figure 2.12b, and using equations (2.1), (2.2), (2.7) and table 2.3 the following formulae are obtained for the different sectors:

#### 1. Sector 1:

$$T_{u\_on} = \frac{T_p}{2} (1 - \mathbf{a}); \ T_{v\_on} = \frac{T_p}{2} (1 + \mathbf{b} - \mathbf{c}); \ T_{w\_on} = \frac{T_p}{2} (1 + \mathbf{a})$$

$$T_{u\_off} = \frac{T_p}{2} (3 + \mathbf{a}); \ T_{v\_off} = \frac{T_p}{2} (3 - \mathbf{b} + \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (3 - \mathbf{a})$$
(2.14)

#### 2. Sector 2:

Quadrant 1: 
$$T_{u\_on} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (3 + \mathbf{a} + \mathbf{b})$$

Quadrant 2:  $T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (3 - \mathbf{a} - \mathbf{b})$ 

$$T_{v\_on} = \frac{T_p}{2} (1 - \mathbf{c}); \ T_{w\_on} = \frac{T_p}{2} (1 + \mathbf{c})$$

$$T_{v\_off} = \frac{T_p}{2} (3 + \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (3 - \mathbf{c})$$
(2.15)

#### 3. Sector 3:

$$T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a}); \ T_{v\_on} = \frac{T_p}{2} (1 - \mathbf{a}); \ T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c})$$

$$T_{u\_off} = \frac{T_p}{2} (3 - \mathbf{a}); \ T_{v\_off} = \frac{T_p}{2} (3 + \mathbf{a}); \ T_{w\_off} = \frac{T_p}{2} (3 + \mathbf{b} - \mathbf{c})$$
(2.16)

## 4. Sector 4:

$$T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a}); \ T_{v\_on} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c}); \ T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{a})$$

$$T_{u\_off} = \frac{T_p}{2} (3 - \mathbf{a}); \ T_{v\_off} = \frac{T_p}{2} (3 + \mathbf{b} - \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (3 + \mathbf{a})$$
(2.17)

5. Sector 5:

Quadrant 3: 
$$T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (3 - \mathbf{a} - \mathbf{b})$$

Quadrant 4:  $T_{u\_on} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (3 + \mathbf{a} + \mathbf{b})$ 

$$T_{v\_on} = \frac{T_p}{2} (1 + \mathbf{c}); \ T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{c})$$

$$T_{v\_off} = \frac{T_p}{2} (3 - \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (3 + \mathbf{c})$$
(2.18)

6. Sector 6:

$$\begin{split} T_{u\_on} &= \frac{T_p}{2} \big( 1 - \mathbf{a} \big) \, ; \ T_{v\_on} = \frac{T_p}{2} \big( 1 + \mathbf{a} \big) \, ; \ T_{w\_on} = \frac{T_p}{2} \big( 1 + \mathbf{b} - \mathbf{c} \big) \\ T_{u\_off} &= \frac{T_p}{2} \big( 3 + \mathbf{a} \big) \, ; \ T_{v\_off} = \frac{T_p}{2} \big( 3 - \mathbf{a} \big) \, ; \ T_{w\_off} = \frac{T_p}{2} \big( 3 - \mathbf{b} + \mathbf{c} \big) \end{split} \tag{2.19}$$

Using these equations provides an easily comprehensible realization of the space vector modulation following the control flow of the structogram of fig. 2.11. The afore mentioned limitation to the maximum voltage vector should be already carried out in the current controller because of the necessary feedback correction discussed later. The normalization of the voltage components to  $2U_{DC}/3$  permits the calculation of the switching times independent of the motor nominal voltage.

## 2.4.2 Modulation with digital signal processor TMS 320C20/C25

Unlike the Siemens microcontroller the digital signal processor is not equipped with the intelligent Capture/Compare register unit, but provides a superior computing power instead. In principle, there are two possibilities for the realization of the space vector modulation.

- 1. Using additional hardware: The processor is extended by a latch-counter-unit providing the process interface to the inverter (refer to fig. 2.13a).
- 2. Without additional hardware: The internal processor timer is used to generate the pulse pattern.

Since the 2<sup>nd</sup> variant causes certain disadvantages, such as an inaccurate voltage realization, particularly at the sector boundaries as well as in the area of small stator voltage (important for the low speed region), the 1<sup>st</sup> variant (following the realization with microcontroller) is discussed first.

The figure 2.13a illustrates the hardware configuration. The figure 2.13b shows, representative of the complete vector space, the definition and respectively the assignment of the turn-on / turn-off times to the inverter legs.



Fig. 2.13a Hardware configuration using DSP with external down-counter

According to the definition the switching times of the sampling period (k) can be calculated and stored in a RAM table. In the next period (k+1) they are output half-pulse wise. Computing and output of the switching times are processed in a time frame with the fixed period  $T_p/2$ , which is

provided by either the internal timer of the signal processor or possibly also by the master-processor in the case of a multi-processor system. At the synchronization instants the switching times for the actual half pulse are automatically transferred from the latches to the down-counters, giving way to write the switching times for the next half pulse from the RAM table into the latch. Thus, output of the switching times independent of the interrupt reaction time is achieved, which results in a very precise voltage realization particularly in the area of small voltage values. After having been loaded with the switching times the counter starts to count backwards. Once the counter reading is zero, a zero detector will generate turn-on/turn-off pulses to control the inverter.



Fig. 2.13b Definition of the turn-on and turn-off times in the version DSP with additional hardware

According to the definition in the figure 2.13b, equation (2.2) and table 2.3 the switching times can be calculated as follows.

## 1. Sector 1:

$$T_{u\_on} = T_{w\_off} = \frac{T_p}{2} (1 - \mathbf{a}); \ T_{u\_off} = T_{w\_on} = \frac{T_p}{2} (1 + \mathbf{a})$$

$$T_{v\_on} = \frac{T_p}{2} (1 + \mathbf{b} - \mathbf{c}); \ T_{v\_off} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c})$$
(2.20)

2. Sector 2:

Quadrant 1: 
$$T_{u\_on} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b})$$

Quadrant 2:  $T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b}); \ T_{u\_off} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b})$ 

$$T_{v\_on} = T_{w\_off} = \frac{T_p}{2} (1 - \mathbf{c}); \ T_{v\_off} = T_{w\_on} = \frac{T_p}{2} (1 + \mathbf{c})$$
(2.21)

3. Sector 3:

$$T_{u\_on} = T_{v\_off} = \frac{T_p}{2} (1 + \mathbf{a}); \ T_{u\_off} = T_{v\_on} = \frac{T_p}{2} (1 - \mathbf{a})$$

$$T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (1 + \mathbf{b} - \mathbf{c})$$
(2.22)

4. Sector 4:

$$T_{u\_on} = T_{w\_off} = \frac{T_p}{2} (1 + \mathbf{a}); \ T_{u\_off} = T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{a})$$

$$T_{v\_on} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c}); \ T_{v\_off} = \frac{T_p}{2} (1 + \mathbf{b} - \mathbf{c})$$
(2.23)

5. Sector 5:

Quadrant 3: 
$$T_{u\_on} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b}); T_{u\_off} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b})$$

Quadrant 4:  $T_{u\_on} = \frac{T_p}{2} (1 - \mathbf{a} - \mathbf{b}); T_{u\_off} = \frac{T_p}{2} (1 + \mathbf{a} + \mathbf{b})$ 

(2.24)

 $T_{v\_on} = T_{w\_off} = \frac{T_p}{2} (1 + \mathbf{c}); T_{v\_off} = T_{w\_on} = \frac{T_p}{2} (1 - \mathbf{c})$ 

6. Sector 6:

$$T_{u\_on} = T_{v\_off} = \frac{T_p}{2} (1 - \mathbf{a}); \ T_{u\_off} = T_{v\_on} = \frac{T_p}{2} (1 + \mathbf{a})$$

$$T_{w\_on} = \frac{T_p}{2} (1 + \mathbf{b} - \mathbf{c}); \ T_{w\_off} = \frac{T_p}{2} (1 - \mathbf{b} + \mathbf{c})$$
(2.25)

The shown variant with additional hardware fulfils highest requirements regarding the precision of the voltage realization. The additional hardware costs are faced by a time resolution, which is practically limited only by the word length of the three counters and their clock frequency.

With regard to a very exact and dynamic feedback control this solution has to be preferred to the one with microcontroller if one considers that the controller has a maximum time resolution of only 400 ns (with hardware expansion also 200 ns possible). This time resolution permits a voltage resolution of only 7 bits at a pulse frequency of 10 kHz (approx. 4 V/time increment) and a resolution of 8 bits at 5 kHz (approx. 2 V/time increment). This is a rather coarse resolution. In contrast to this, a time resolution of 50 ns corresponding to a voltage resolution of 10 bits (approx. 0.5 V/time increment) can easily be achieved, which requires just the use of counters with 10 bit word length and 10 MHz clock frequency. Another drawback of the microcontroller solution is due to the fact that the CAP/COM registers of the SAB 80C166 cannot be switched simultaneously because they are subject to a skew of 50 ns from register to register. This necessitates a hardware-based compensation to attain a high precision of the voltage realization. Such a compensation is particularly important at the sector boundaries as well as in the area of small voltages or small speeds.

For the DSP solution, the version without additional hardware offers itself as an alternative possibility. The switching times are generated using the only internal timer. The figure 2.14a shows the used hardware. The figure 2.14b shows the time frame, in which the switching time calculation as well as their output are processed. As familiar, the switching times are calculated and stored into a RAM table already in the period (k) for the following period (k+1). The difference, compared with the two previous solutions, consists in the switching times not being output to the inverter separately for every phase in the form of  $T_{on}$  and  $T_{off}$ , but in original form as  $T_{in}$ ,  $T_{ij}$  or  $T_{0,7}$  together with the needed switching state. The respective switching state is sent as a 3 bit data block to a buffer latch ahead of the inverter which holds it for the complete period.

From figure 2.14b it becomes evident, that two information are relevant about the modulation: the switching time and the switching state. These information are determined using table 2.3 and the flow chart in the figure 2.11, depending on the sector the voltage vector is located in. The hold time of the switching state was fetched from the RAM table and loaded into the period register PRD before. The timer counts backwards and when reaching zero activates the automatic loading of the new time constant from the PRD into its own counter register. At the same time, it triggers an interrupt request Tint, which activates an interrupt routine for handing over the following switching state (pulse pattern) into the latch as well as reloading the PRD.



Fig. 2.14a Hardware configuration using DSP with its internal timer TIM

To output the switching states the following simple algorithm can be used. If again the figure 2.14b for the sector  $S_1$  is viewed as an example the following assignment table can be composed.

| Switching times  | $T_r$ | $T_l$ | $T_7$ | $T_l$ | $T_r$ | $T_0$ |
|------------------|-------|-------|-------|-------|-------|-------|
| Switching states | 100   | 110   | 111   | 110   | 100   | 000   |

The phases u, v and w are assigned to the data bits D0, D1 and D2. If the switching states of the above table are now written in reversed order 000 / 001 / 011 / 111 / 011 / 001,

a so-called control word (CW) results with CW=17D9h as a hexadecimal number. The control words for all six sectors can be summarized like in table 2.4.

Table 2.4 Control words of all sectors

| Sectors       | $S_1$ | $S_2$ | $S_3$ | $S_4$ | $S_5$ | $S_6$ |
|---------------|-------|-------|-------|-------|-------|-------|
| Control words | 17D9h | 27DAh | 2DF2h | 4DF4h | 4BECh | 1BE9h |



Fig. 2.14b Modulation time frame of the solution without additional hardware

The control word, corresponding to the determined sector is loaded by the interrupt routine from the memory into the accumulator, submitted to the latch, shifted three times to the right (to remove the switching state), and then stored back into the RAM. Every time after the control word has arrived in the accumulator, a zero test is carried out. The value zero indicates a new control word for the next sampling period. The described handling of the control words is illustrated again by the flow chart in figure 2.14c.

Some disadvantages of this method shall be mentioned now. The figure 2.14a is redrawn for two extreme cases:

- 1. the areas of small voltages at the sector boundaries, and
- 2. the area of voltage limitation (refer to fig. 2.14d).



**Fig. 2.14c** Flow chart of the interrupt routine to output switching times and switching states

Changing the switching states by means of an interrupt routine reacting to  $T_{int}$  implies that the interval between two changes must be longer than the interrupt reaction time and respectively the run time of the interrupt routine itself. The figure 2.14d (refer to fig. 2.6) shows for sector  $S_1$  that:

- 1. near the sector boundaries one of the two times  $T_r$  or  $T_l$ , and
- 2. in case of small voltages both times  $T_r$  and  $T_l$

may fall below the reaction time of the interrupt routine. In the 1<sup>st</sup> case the boundary vector with the smaller switching time must be suppressed, and the second one will be realized for the whole period instead. This, of course, causes an inaccuracy of the voltage realization. In the 2<sup>nd</sup> case the voltage amplitude in the vicinity of zero is limited on the lower end, which has a negative effect on the speed control at small speeds.



**Fig. 2.14d** Switching times at sector boundaries, in the area of small voltage (**left**) or of voltage at upper limits (**right**)

At large voltage amplitudes or during transients (magnetization, field-weakening, speed-up, speed reversal) the zero times  $T_0$  and  $T_7$  can become very small, and also fall below the reaction time of the interrupt routine (fig. 2.14d right). This means a limitation of the voltage amplitude on its upper end.

# 2.4.3 Modulation with double processor configuration

In this section a double processor system is introduced combining harmonically the strength of the digital signal processor TMS 320C25 – with respect to computing power – with the strength of the microcontroller SAB C167 – with respect to peripheries.

In this configuration the DSP is responsible for the processing of the near-motor control functions, and the  $\mu C$  has to process the tasks of the superposed control loops. The DSP allows to calculate the extensive real time algorithms, part of which is also the space vector modulation within a small sampling time of 100...200  $\mu s$ . In every sampling period the DSP stores the newly calculated switching times into its own RAM, they are read from the  $\mu C$  memory driver using HOLD/HOLDA signals and submitted to the  $\mu C$ -internal PWM units. That means, with respect to the modulation the  $\mu C$  is only responsible for the output of the switching times and for the control of the transistor legs.



Fig. 2.15a Overview of the double processor configuration DSP -  $\mu$ C

The microcontroller SAB C167 contains, different to the earlier SAB 80C166, four timers PT0...PT3. In the symmetrical modulation mode these timers work as up/down counters. After every forward and the following backward counting process, when the counter content has reached the value zero, the timer/counter automatically receives the new maximum counter content from one of the four period registers PP0...PP3 for the new counting period. For the modulation only three registers of each category are needed (fig. 2.15b). It can be easily recognized that the three registers PP0, PP1 and PP2 have to get the same value simultaneously to realize the same counting or modulation periods. Furthermore it can be easily recognized that these three registers have to be initialized only once with the value  $T_p=1/f_p$  because of the constant pulse frequency  $f_p$ .

In comparison with the SAB 80C166 the registers PT0, PT1, PT2 play the role of T0, and the registers PP0, PP1, PP2 the role of T0REL (refer to fig. 2.12a). The registers PW0, PW1 and PW2 generate the pulse widths. The assignment of the registers to the transistor legs is shown in the figure 2.15b.



Fig. 2.15b Simplified structure of the modulation registers of the SAB C167



Fig. 2.15c Definition of the switching times for the structure in the figure 2.15b

While PT0, PT1 and PT2, which are represented as PWM timers in figure 2.15c, are counting forwards and backwards, their values are permanently compared with the contents of the corresponding pulse width registers PW0, PW1 and PW2. Respective compare-match events cause the output ports POUT0, POUT1, POUT2 to toggle and in due course the switchover of the corresponding inverter legs.

The figure 2.15c shows that the pulse width registers PW0, PW1 and PW2 have to be reloaded with new switching times, for turn-on and turn-off, only once per modulation period. The switching times can be calculated according to the definition in figure 2.15c as follows.

#### 1. Sector 1:

$$T_u = \frac{T_p}{2} (1 + \mathbf{a}); \ T_v = \frac{T_p}{2} (1 - \mathbf{a} + 2\mathbf{c}); \ T_w = \frac{T_p}{2} (1 - \mathbf{a})$$
 (2.26)

2. Sector 2:

Quadrant 1: 
$$T_u = \frac{T_p}{2} (1 + 2\mathbf{b} + \mathbf{c})$$
; Quadrant 2:  $T_u = \frac{T_p}{2} (1 - 2\mathbf{a} + \mathbf{c})$   

$$T_v = \frac{T_p}{2} (1 + \mathbf{c}); T_w = \frac{T_p}{2} (1 - \mathbf{c})$$
(2.27)

3. Sector 3:

$$T_u = \frac{T_p}{2} (1 - \mathbf{a}); \ T_v = \frac{T_p}{2} (1 + \mathbf{a}); \ T_w = \frac{T_p}{2} (1 + \mathbf{a} - 2\mathbf{c})$$
 (2.28)

4. Sector 4:

$$T_u = \frac{T_p}{2} (1 - \mathbf{a}); \ T_v = \frac{T_p}{2} (1 + \mathbf{a} - 2\mathbf{c}); \ T_w = \frac{T_p}{2} (1 + \mathbf{a})$$
 (2.29)

5. Sector 5:

Quadrant 3: 
$$T_u = \frac{T_p}{2} (1 - 2\mathbf{a} + \mathbf{c})$$
; Quadrant 4:  $T_u = \frac{T_p}{2} (1 + 2\mathbf{b} + \mathbf{c})$   

$$T_v = \frac{T_p}{2} (1 - \mathbf{c}); T_w = \frac{T_p}{2} (1 + \mathbf{c})$$
(2.30)

6. Sector 6:

$$T_u = \frac{T_p}{2} (1 + \mathbf{a}); \ T_v = \frac{T_p}{2} (1 - \mathbf{a}); \ T_w = \frac{T_p}{2} (1 - \mathbf{a} + 2\mathbf{c})$$
 (2.31)

To complete the chapter of the realization examples the figure 2.16 shows the switching time plots, produced by the structure in figure 2.15b, at great voltages. This may be easily recognized by the fact that the switching times also show values near zero.



**Fig. 2.16** The phase voltage  $u_{su}$  with the corresponding switching time  $T_u$  (**top**), and the switching times  $T_u$ ,  $T_v$ ,  $T_w$  (**bottom**)

# 2.5 Special modulation procedures

## 2.5.1 Modulation with two legs

Starting point for this section is figure 2.9, which represents the standard modulation in a stable time frame. The standard modulation realizes the same voltage vector, which is determined by the lengths of its boundary vector times  $T_n$ ,  $T_l$ , twice per pulse period. For the purpose of comparison it is represented again for the sector  $S_1$  in figure 2.17a.

We will try now to combine the zero times  $T_0$ ,  $T_7$  such that their sum is output either equally distributed at the ends (fig. 2.17b) or concentrated in the center (fig. 2.17c) of the pulse period. The times  $T_r$ ,  $T_l$  or the voltage vector to be realized remain unchanged. With respect to the mean average value the two new sequences realize the same vector as in figure 2.17a.

It is obvious in the newly arisen sequences, that only two inverter legs are actually switched over. If this method, which will be called *modulation* with two legs from now on, is used consistently for the whole vector space, then the switching losses automatically go down to approx. 2/3 of the original value.

From the figures 2.17b,c it becomes obvious that either the phase with the smallest pulse width (for  $S_1$ : phase w) or the phase with the smallest pause time (for  $S_1$ : phase u) would be clamped to negative potential (the lower transistor of a phase leg is conducting) or to positive potential (the upper transistor is conducting). The formulae for the calculation of the switching times depend on the hardware and can be derived according to the definition from section 2.4.



Fig. 2.17 Modulation with two legs for sector S<sub>1</sub>

With the help of the firing pulse patterns in figures 2.4a...e, the suitable clamping phases or transistor legs can be found for all sectors and are summarized in the table in figure 2.18. For each sector two phases are available alternatively.

To obtain the same switching losses for all transistors, the upper transistor of one leg (corresponding phase on +) and then the lower transistor of the next leg (corresponding phase on -) are alternately switched on permanently for an angular range of 60°. To switch-over the clamping to the next phase,

- 1. either the sector boundaries (figure 2.18b),
- 2. or the middle points of the sectors (figure 2.18c)

can be used. For all variants every transistor of the inverter conducts only for  $60^0$  per rotation of the voltage vector. With regard to the switching

time calculation, which already requires a sector selection (refer to table 2.3), the version shown in figure 2.18b, seems to be more suitable for the practical implementation compared to the one in figure 2.18c.



**Fig. 2.18** Possibilities of modulation with two legs: Possible phases for clamping per sector (a), and ways to switchover the clamped phases (b, c)

The advantage of the lower switching losses, however, is faced by considerably higher current harmonics, about twice the ripple amplitude has to be expected compared to the standard PWM algorithm.

#### 2.5.2 Synchronous modulation

For the modulation algorithms discussed so far, it was always assumed that the pulse period  $T_p$  or the pulse frequency  $f_p = 1/T_p$  is kept constant. However, since the fundamental frequency or the stator frequency  $f_s$  of the driven motor depends on the speed as well as on the load and is therefore

variable, the relationship  $f_p/f_s$  is not constant. In this case one speaks of asynchronous modulation. The pulse period and the fundamental voltage period are not in any fixed relation.

This asynchronous characteristic causes subharmonics and losses as well as torque oscillations, which do not play an important role, as long as the relationship  $f_p/f_s$  is sufficiently large. The negative influence of the asynchronous characteristic may become a significant problem for high-speed drives (centrifuges, vacuum pumps etc.) in the speed range of 30000...60000 rpm. This problem can be avoided by keeping  $f_p$  and  $f_s$  in a fixed relationship.

$$N = \frac{f_p}{f_s} = const$$

$$T_p = \frac{1}{f_p} = \frac{1}{N f_s} = const$$
(2.32)

N is the number of the pulse periods per fundamental wave and may assume – because of the three-phase symmetry of the machines – only values, which fit the following relationship.

$$N = 9 + 6n$$
  $n = 0, 1, 2, 3, ...$   
 $N = 9, 15, 21, 27, ...$  (2.33)

In principle the modulation is processed in the same way as for the asynchronous algorithm, only, that the length of the pulse period  $T_p$  – depending on the working frequency  $f_s$  – must be recalculated permanently. It has to be taken into account for the practical implementation, that the value of the period register cannot be changed during the current pulse period, although the new value is already available after the recalculation is finished. This requires a *double buffering of the period register*. However, not every microcontroller will have the ability of double buffering. Regarding this feature the SAB C167 is very recommendable because the registers PP0, PP1, PP2 and PP3 are doubly buffered by the so-called *"shadow register*".

The following problems must be taken into account for the application of the method:

1. Switching over of the pulse number *N* is carried out depending on the working (fundamental) frequency, and a *hysteresis* – *to prevent continuous to- and from-switching* – must be installed.

<sup>&</sup>lt;sup>1)</sup> Note: This ability is a further development of the SAB C167 in newer versions. The SAB C167 in the first version does not have double buffering for period registers.

2. Switching over of the pulse number N as well as switching over between asynchronous and synchronous modulation must - to reduce transient effects – take place at the sector boundaries where one of the phase voltages  $u_{su}$ ,  $u_{sv}$  and  $u_{sw}$  reaches its peak value. At the sector boundaries the current harmonics pass through their zero crossings.

#### 2.5.3 Stochastic modulation

In this chapter we shall take a closer look at the switching frequency harmonics produced by the modulation and discuss certain ways to take influence on their appearance. Typical spectra of inverter voltage and current for the standard modulation with fixed pulse width are shown in figure 2.19. Their shape depends on the modulation ratio  $m = |\mathbf{u}_s|/u_{\text{max}}$  and in case of the current on the load characteristic.



**Fig. 2.19** Voltage (top) and current (bottom) spectra for standard modulation with m = 0.4 and pulse frequency = 1.0 kHz; current fundamental is truncated!

The spectra show pronounced maxima at the pulse frequency and its multiples with the overall maximum at the  $2^{nd}$  harmonic. Because of the low-pass characteristic of the load (R-L) harmonics beyond the  $4^{th}$  are suppressed in the current. Depending on the application and performance requirements, both positive and negative effects arise from this kind of spectrum:

- Below the switching frequency and its sidebands appear only low harmonic amplitudes and consequently their effect on ripple control frequencies in grid applications (active front-end converters) is negligible.
- The maximum harmonic current amplitudes are concentrated around two specific frequencies (1<sup>st</sup> and 2<sup>nd</sup> order), which facilitates filtering.
- Especially for grid applications, the maxima at 1<sup>st</sup> and 2<sup>nd</sup> switching frequency harmonic may exceed the limits specified in the applicable grid codes, which requires additional filtering for their suppression.
- The pronounced single-frequency harmonics produce noise which may be unwanted and experienced as disturbing in many environments.

To overcome the mentioned negative effects, it would in the first place be necessary to get rid of the pronounced 1<sup>st</sup> and 2<sup>nd</sup> harmonics and to obtain a more uniformly distributed spectrum. A straightforward solution could be to elude to control strategies with variable pulse period, such as bang-bang control, predictive control or direct torque/flux control. This is however outside the scope of this book, since we want to rely on the current control procedures to be discussed in the later chapters. So the question is how we can achieve a distributed spectrum while keeping a constant pulse period at the same time.

To derive respective procedures, it is first necessary to take a closer look on how the harmonic frequencies originate. Figure 2.20 shall help to do this. In both phase voltage and inverter control signals two repeating patterns may be identified:

- 1. The first pattern is formed by the ever repeating sequence of zero and active vectors ... 0-R-L-7-7-L-R-0 ... which appears with switching frequency and multiples of it.
- 2. The second one is formed by regular blocks of the active vectors R and L which are interrupted by zero vectors 0/7 with symmetric distribution within one period. This pattern is responsible for the especially strong 2<sup>nd</sup> harmonic in the spectrum and its multiples.

To shape a distributed spectrum, the regularity of these patterns has to be overcome, we have to "break the symmetries". Two methods shall be discussed to achieve this task.

The first approach, "sequence randomizing", breaks the first symmetry pattern by randomly changing the start vector of the pulse period between 0 and 7. This implies to add an additional simultaneous switchover of all three phase legs at the beginning of the pulse period. The start vector for each period is determined by a pseudo-random binary sequence (PRBS) which can easily be generated in a microcontroller. The resulting pulse patterns and spectra are shown in figures 2.21 and 2.22.



**Fig. 2.20** Switching pattern of phase voltage (**top**, center) and phase control signals u/v/w (**bottom**) for standard modulation



**Fig. 2.21** Switching pattern of phase voltage (**top**) and phase control signals u/v/w (**bottom**) for modulation with sequence randomizing



Fig. 2.22 Voltage (top) and current (bottom) spectra for modulation with sequence randomizing

The described change of the vector sequence occurs in the example between first and second pulse period in fig. 2.21. The peak value of the first harmonic is clearly reduced but, since nothing is changed on the zero vector lengths, the second symmetry pattern and therefore the second harmonic remain largely unaffected.

The  $2^{\rm nd}$  harmonic is addressed with a different approach, which we will call "zero vector randomizing". The symmetrical distribution of  $u_0$  and  $u_7$  inside one period in the standard modulation scheme is dropped in favor of a randomly chosen ratio between both vectors, while keeping their symmetry with regard to the center of the pulse period. The latter is an important condition to maintain the coincidence between sampling instant of the phase current and the current fundamental (refer to chapter 4.1). With an uniformly distributed random number r(k) where  $0 \le r(k) \le 1$  and the original zero vector time  $T_{00}$ , the resulting zero vector times can be calculated from:

$$T_0 = r(k)T_{00}$$

$$T_7 = (1 - r(k))T_{00}$$
(2.34)

As it turns out in the practical implementation, the results become more impressive when the extremes of the r(k) interval  $\{0; 1\}$  are stronger emphasized, i.e. r(k) is calculated by:

$$\begin{split} r(k) &= k_r (r_1(k) - 0.5) + 0.5 \\ k_r &= 2, 3, ..., 8 \\ 0 &\leq r(k) \leq 1 \end{split} \tag{2.35}$$

 $0 \le r_1(k) \le 1$  an uniformly distributed random number

It must be mentioned, that the effectiveness of zero vector randomizing of course depends on the modulation ratio  $m = |\mathbf{u}_s|/u_{\text{max}}$ , since m determines the available space for the zero vector variation. Near the maximum voltage vector the effect will be minimal.

It must also be noted, that the total harmonic current, and therefore the total harmonic distortion (THD) value cannot essentially be changed by modifying the modulation scheme. Thus, reducing harmonics in one area of the spectrum inevitably will shift them to and increase them in another area.

Figures 2.23 and 2.24 again show resulting sample pulse patterns and spectra, both figures for combined sequence randomizing and zero vector randomizing and at the same operating point as in the figures above.



**Fig. 2.23** Switching pattern of phase voltage (**top**) and phase control signals u/v/w (**bottom**) for modulation with combined sequence randomizing and zero vector randomizing



**Fig. 2.24** Voltage (**top**) and current (**bottom**) spectra for modulation with combined sequence randomizing and zero vector randomizing

## 2.6 References to chapter 2

Choi JW, Yong SI, Sul SK (1994) Inverter output voltage synthesis using novel dead time compensation. Proc. IEEE Applied Power and Electronics Conf., pp. 100-106

Kiel E (1994) Anwendungsspezifische Schaltkreise in der Drehstrom-Antriebstechnik. Dissertation, TU Carolo-Wilhemina zu Braunschweig

Lipp A (1989) Beitrag zur Erarbeitung und Untersuchung von online Algorithmen für die digitale Ansteuerung von Pulsspannungswechselrichtern zur Drehzahlstellung von Drehstromasynchronmaschinen. Dissertation, TU Ilmenau

Mohan N, Undeland TM, Robbins WP (1995) Power electronics: Converters, Applications, and Design. 2<sup>nd</sup> Edition, John Wiley & Sons, Inc.

Pollmann A (1984) Ein Beitrag zur digitalen Pulsbreitenmodulation bei pulswechselrichtergespeisten Asynchronmaschinen. Dissertation, TU Carolo-Willhelmina zu Braunschweig

Quang NP (1991) Schnelle Drehmomenteinprägung in Drehstromstellantrieben. Dissertation, TU Dresden

Quang NP, Wirfs R (1995) Mehrgrößenregler löst PI-Regler ab: Ein Umrichterkonzept für Drehstromantriebe. Elektronik, H.7, S. 106-110

- Rashid MH (2001) Power Electronics Handbook. Academic Press
- Schröder D (1998) Elektrische Antriebe: Leistungselektronische Schaltungen. Springer Verlag, Berlin Heidelberg Paris London New York Tokyo
- Siemens AG (1990) Microcomputer Components SAB 80C166 / 83C166. User's Manual
- Siemens AG (2003) C167CR Derivatives 16-Bit Single-Chip Microcontrollers. User'Manual, V3.2
- Siemens AG (2005) TC116x Series 32-Bit Single-Chip Microcontrollers. User'Manual, V1.2
- Texas Instruments (1990) Digital Signal Processing Products TMS 320C2×. User's Guide
- Texas Instruments (2004) TMS 320F2812 Digital Signal Processors. Data Manual Yen-Shin L (1999) Sensorless Vector-Controlled IM Drives using Random Switching Technique, Proc. EPE '99 Lausanne